Background


Data Collection

Data Configuration

We have species composition data from 1031 1m^2 quadrats representing 27 sites.

Nearly all statistical packages require the data to be in a presence-absence form. There are several ways to do it (one of which can maintain cover values rather than changing it to binary data); I used a loop function. The result is a presence-absence matrix with Site as a column so subsamples can be organized accordingly. This column must be deleted for every analysis, however!

Table 1. Sample of data in presence-absence format.
Site SCICYP PROPEC JUNDEB JUNREP CXJOOR CXLOUI
1.1.1 1 1 1 1 1 1 0
1.1.2 1 1 1 1 0 0 1
1.1.3 1 1 1 0 0 0 1
1.1.4 1 1 1 0 0 1 1
1.1.5 1 0 0 0 0 0 1

Diversity Estimates

Sites had widely varying observed total richness. The use of extrapolated species accumulation curves can tell us how many species are likely to be at the site based on how many were found in accumulating subsamples. However if a curve never flattens, it gives a wild estimate of richness (see Site 10).

What do the curves that made these estimates look like? Let’s take a look!

This plot is not particularly helpful other than to visualize the general span of observed and expected richnesses and sampling efforts. Examining the curves in portions of 3-4 is necessary to

These curves illustrate not only where the flattening point (expected richness) occurs, but also how quickly. Examining a curve can allow someone to estimate how many more samples would be needed to reach that point, however if doing so samples a larger area then the curve may never flatten.

Let’s see if sampling effort (# quadrats/area sampled) affected percent estimated sampling completion; if it did, that would be a big problem and I would have a lot of explaining to do to my committee.

There is no relationship between sampling effort and completion percentage (p=0.6366006). However, note that Sites 10 and 26 were flagged as outliers by the autoplot function. This inadequate sampling is likely the result of too few quadrats sampled at the wetland edge relative to the size of the wetland.

Effects on Diversity


There appears to be a relationship between site richness and site area, but unexpectedly this relationship appears to be negative. Because the data are likely non-linear, a generalized linear model should be used to assess this relationship.

Community Classification

Which sites are similar?

There may be a lot of overlap in clusters due to the nestedness of some community types. We should revisit this later using quadrats as replicates.

Are sites similar because they’re geographically closer?

ggplot(distance.f, aes(x=distance.f$geographic, y=distance.f$Sorensen)) +
  geom_point()+
  geom_smooth(method="glm", method.args=list(family="binomial"(link="logit")))+
  ylab("Sorensen dissimilarity index")+
  xlab("Geographic distance (m)")+
  ggtitle("Geographic distance between sites has no effect on species similarity")+
  coord_cartesian(ylim = c(0, 1))
non-integer #successes in a binomial glm!

Call:
glm(formula = Sorensen ~ geographic, family = binomial, data = distance.f)

Deviance Residuals: 
     Min        1Q    Median        3Q       Max  
-1.13785  -0.13608   0.02589   0.19654   0.64852  

Coefficients:
             Estimate Std. Error z value Pr(>|z|)    
(Intercept) 1.427e+00  1.626e-01   8.777   <2e-16 ***
geographic  6.933e-07  1.764e-06   0.393    0.694    
---
Signif. codes:  0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1

(Dispersion parameter for binomial family taken to be 1)

    Null deviance: 43.121  on 701  degrees of freedom
Residual deviance: 42.966  on 700  degrees of freedom
AIC: 298.02

Number of Fisher Scoring iterations: 4

Ordinations

Implications

Plant communities aren’t real. We can all go home now.

---
title: "Deterministic processes drive wetland plant community composition and diversity"
author: "C. M. Ciafré"
output:
  html_notebook:
    df_print: paged
    rows.print: 10
    theme: journal
    highlight: zenburn
    number_sections: no

---
#   {.tabset .tabset-fade}
```{r setup, NOTICE USE of PACMAN, include=FALSE}
#install pacman first to automatically install and load any needed packages
pacman::p_load(ggplot2, dplyr, tidyr, reshape, iNEXT, knitr, kableExtra, ggfortify, ggpubr, vegan, geosphere, mclust)

#Not sure why I keep this in
knitr::opts_chunk$set(echo = TRUE)

#Load data
sppxsites<-read.csv("data/VEGDATADONE.csv", header=TRUE)
sitenames<-read.csv("data/SiteNames.csv", header=TRUE)
sitesizes<-read.csv("data/SiteXsize2.csv", header=TRUE)
quaddatas<-read.csv("data/quadmetrics.csv", header=TRUE)
colnames(quaddatas)[colnames(quaddatas)=="Depth..m."] <- "Depth"
colnames(quaddatas)[colnames(quaddatas)=="X..Canopy"] <- "Canopy"
colnames(quaddatas)[colnames(quaddatas)=="Pond"] <- "Site"
#Note: there is no Site 15; it was ditched halfway through sampling because it was not independent from Site 14.
```

## Background 

<figure>
<img src="Images/QuadratCropped.jpg"></figure><br>

### Data Collection

### Data Configuration

We have species composition data from 1031 1m^2 quadrats representing 27 sites.

Nearly all statistical packages require the data to be in a presence-absence form. There are several ways to do it (one of which can maintain cover values rather than changing it to binary data); I used a loop function. The result is a presence-absence matrix with Site as a column so subsamples can be organized accordingly. This column must be deleted for every analysis, however!

```{r Loop magic, cache=TRUE, include=FALSE}
sites_sub<-unique(sppxsites$ID)
spp_sub<-unique(sppxsites$Species)

#Make a matrix with loop function
spp_commat <- matrix(0, length(sites_sub), length(spp_sub))
for (i in 1:nrow(spp_commat)){temp_sites <- sppxsites[which(sppxsites$ID == sites_sub[i]),]
  spp_commat[i, which(spp_sub%in%temp_sites$Species)]<- 1
  print(i)}

#Name rows and Columns
rownames(spp_commat) <- as.character(sites_sub)
colnames(spp_commat) <- as.character(spp_sub)

#Change matrix into dataframe
spp_commat.df<- as.data.frame(spp_commat)

#Make empty quadrats truly empty
spp_commat.df.fixed<-subset(spp_commat.df, select=-c(Empty))

#Add site column back in and change its name
AllPonds <- cbind(sitenames$Pond,spp_commat.df.fixed)
names(AllPonds)[names(AllPonds)=="sitenames$Pond"] <- "Site"
```

```{r Kable 1, echo=FALSE}
AllPondsTrimmed<-select(AllPonds, c(1:7))
kable(AllPondsTrimmed[1:5, ], format = "pandoc", full_width=F, caption = 'Table 1. Sample of data in presence-absence format.')
```


## Diversity Estimates

```{r Split sites, include=FALSE}
#Break up AllPonds into dataframes by site
#The first column has to be removed for each
#Transpose the dataframes so species are columns

S01<-t(select(filter(AllPonds, Site == 1), -1))
S02<-t(select(filter(AllPonds, Site == 2), -1))
S03<-t(select(filter(AllPonds, Site == 3), -1))
S04<-t(select(filter(AllPonds, Site == 4), -1))
S05<-t(select(filter(AllPonds, Site == 5), -1))
S06<-t(select(filter(AllPonds, Site == 6), -1))
S07<-t(select(filter(AllPonds, Site == 7), -1))
S08<-t(select(filter(AllPonds, Site == 8), -1))
S09<-t(select(filter(AllPonds, Site == 9), -1))
S10<-t(select(filter(AllPonds, Site == 10), -1))
S11<-t(select(filter(AllPonds, Site == 11), -1))
S12<-t(select(filter(AllPonds, Site == 12), -1))
S13<-t(select(filter(AllPonds, Site == 13), -1))
S14<-t(select(filter(AllPonds, Site == 14), -1))
S16<-t(select(filter(AllPonds, Site == 16), -1))
S17<-t(select(filter(AllPonds, Site == 17), -1))
S18<-t(select(filter(AllPonds, Site == 18), -1))
S19<-t(select(filter(AllPonds, Site == 19), -1))
S20<-t(select(filter(AllPonds, Site == 20), -1))
S21<-t(select(filter(AllPonds, Site == 21), -1))
S22<-t(select(filter(AllPonds, Site == 22), -1))
S23<-t(select(filter(AllPonds, Site == 23), -1))
S24<-t(select(filter(AllPonds, Site == 24), -1))
S25<-t(select(filter(AllPonds, Site == 25), -1))
S26<-t(select(filter(AllPonds, Site == 26), -1))
S27<-t(select(filter(AllPonds, Site == 27), -1))
S28<-t(select(filter(AllPonds, Site == 28), -1))
```

```{r Unicorn vomit prep, fig.height=6, fig.width=10, message=FALSE, warning=FALSE, cache=TRUE, include=FALSE}
#Make a list of all site dataframes
site.list.all = list(S01=S01,S02=S02,S03=S03,S04=S04,S05=S05,S06=S06,S07=S07,S08=S08,S09=S09,S10=S10,S11=S11,S12=S12,S13=S13,S14=S14,S16=S16,S17=S17,S18=S18,S19=S19,S20=S20,S21=S21,S22=S22,S23=S23,S24=S24,S25=S25,S26=S26,S27=S27,S28=S28)
#Convert everything in list to incidence frequencies
site.list.freq.all = lapply(site.list.all, as.incfreq)
```

```{r Unicorn vomit prep2, fig.height=6, fig.width=10, message=FALSE, warning=FALSE, cache=TRUE, include=FALSE}
out.inc.all<-iNEXT(site.list.freq.all, q=0, datatype="incidence_freq", nboot=10000)
```

```{r Kable 2, include=FALSE}
#The iNEXT output ("out.inc.all") contains three tables; "AsyEst" has all the data we need
#Saved it as an object and changed it so it would be more readable
RichDiv<-out.inc.all$AsyEst
RichDivT<-subset(RichDiv, select=-c(s.e., LCL, UCL))
RichDivObs<-subset(spread(RichDivT, Diversity, Observed), select=-c(Estimator))
RichDivEst<-subset(spread(RichDivT, Diversity, Estimator), select=-c(Observed))

#Trim down column names so they don't suck
names(RichDivObs)<-c("Site", "RichnessObs", "ShannonObs", "SimpsonObs")
names(RichDivEst)<-c("Site", "RichnessExp", "ShannonExp", "SimpsonExp")

#Collapse sites; have to do funky things to deal with NAs
compress <- function(x) c(na.omit(x), NA)[1]
RichDivObs.1<-aggregate(RichDivObs[2:4], RichDivObs[1], compress)
RichDivEst.1<-aggregate(RichDivEst[2:4], RichDivEst[1], compress)

#Remove site column from RichDivEst so it's not duplicated when merging
RichDivEst.2<-subset(RichDivEst.1, select=-c(Site))

#Merge everybody together
RichDivFinal<-cbind(RichDivObs.1, RichDivEst.2)

#Reorder columns so they make sense
RichDivTab<-RichDivFinal[,c(1,2,5,3,6,4,7)]
RichDivKab<-RichDivTab[c(1, 6, 7, 8, 10, 26, 27),]

kable(RichDivKab[1:7,], format = "pandoc", full_width=F, caption = 'Table 2. Observed and expected Hill numbers from a portion of the sites.')
```

```{r Est and Obs Richness, echo=FALSE, fig.height=4, fig.width=10, message=FALSE, warning=FALSE}
RichnessOnly<-filter(RichDiv, Diversity == "Species richness")
colnames(RichnessOnly)[colnames(RichnessOnly)=="LCL"] <- "RichLCL"
colnames(RichnessOnly)[colnames(RichnessOnly)=="UCL"] <- "RichUCL"
colnames(RichnessOnly)[colnames(RichnessOnly)=="Estimator"] <- "Estimated"
RichGath<-gather(RichnessOnly,Richness,value,Observed:Estimated)
RichSize<- cbind(RichGath, sitesizes$Quadrats)
colnames(RichSize)[colnames(RichSize)=="sitesizes$Quadrats"] <- "Quadrats"


ggplot(RichGath, aes(x=Site, y=value, color=Richness)) +
  scale_color_manual(values=c("darkgrey", "black"))+
  geom_errorbar(aes(ymin=RichLCL, ymax=RichUCL), width=.3, color="darkgrey") +
  geom_point(size=2)+
  ylab("Species Richness")+
  coord_cartesian(ylim = c(0, 250))+
  ggtitle("Estimated and observed species richness by site, with 95% confidence intervals.")+
  labs(caption="Note that upper confidence interval for Site 26 extends to 262.8 and Site 10 extends to 408.52.")+
  theme(axis.title=element_text(size=14), plot.title = element_text(size=14))
```

Sites had widely varying observed total richness. The use of extrapolated species accumulation curves can tell us how many species are likely to be at the site based on how many were found in accumulating subsamples. However if a curve never flattens, it gives a wild estimate of richness (see Site 10).

What do the curves that made these estimates look like? Let's take a look!

```{r Unicorn vomit, echo=FALSE, fig.height=6, fig.width=10, message=FALSE, warning=FALSE, cache=TRUE}
ggiNEXT(out.inc.all, type=1, color.var="site") + 
  theme_bw(base_size = 18) +
  ylab("Species Richness") +
  xlab("Number of Quadrats") +
  ggtitle("Interpolated and extrapolated richness") +
  labs(caption="B=10000.")
```

This plot is not particularly helpful other than to visualize the general span of observed and expected richnesses and sampling efforts. Examining the curves in portions of 3-4 is necessary to 

```{r Smaller curves 1, include=FALSE}
#List the dataframes, then convert them into incidence frequencies
#I broke them into manageable chunks that graph more clearly than everything at once

site.list.1 = list(S03=S03, S08=S08,  S09=S09, S28=S28)
site.list.freq.1 = lapply(site.list.1, as.incfreq)

site.list.2 = list(S01=S01, S02=S02,  S11=S11, S27=S27)
site.list.freq.2 = lapply(site.list.2, as.incfreq)

site.list.3 = list(S10=S10, S13=S13, S14=S14, S23=S23)
site.list.freq.3 = lapply(site.list.3, as.incfreq)


site.list.4 = list(S05=S05,S12=S12, S17=S17)
site.list.freq.4 = lapply(site.list.4, as.incfreq)

site.list.5 = list( S19=S19, S20=S20, S21=S21, S25=S25)
site.list.freq.5 = lapply(site.list.5, as.incfreq)

site.list.6 = list(S06=S06, S16=S16, S22=S22, S26=S26)
site.list.freq.6 = lapply(site.list.6, as.incfreq)

site.list.7 = list(S04=S04, S07=S07, S18=S18, S24=S24)
site.list.freq.7 = lapply(site.list.7, as.incfreq)
```

```{r Smaller curves 2, echo=FALSE, fig.height=4, fig.width=7, message=FALSE, warning=FALSE, cache=TRUE}
#Richness (q=0), Shannon Div (q=1), Simpson Div (q=2)
#Use grey=TRUE to make all lines black
out.inc1<-iNEXT(site.list.freq.1, q=0, datatype="incidence_freq", size=NULL, nboot=100)
A<-ggiNEXT(out.inc1, type=1, color.var="site") + 
  theme_bw(base_size = 18) +
  ylab("Species Richness") +
  xlab("Number of Quadrats") +
  labs(caption="B=100.")

out.inc2<-iNEXT(site.list.freq.2, q=0, datatype="incidence_freq", size=NULL, nboot=100)
B<-ggiNEXT(out.inc2, type=1, color.var="site") + 
  theme_bw(base_size = 18) +
  ylab("Species Richness") +
  xlab("Number of Quadrats") +
  labs(caption="B=100.")

out.inc3<-iNEXT(site.list.freq.3, q=0, datatype="incidence_freq", size=NULL, nboot=100)
C<-ggiNEXT(out.inc3, type=1, color.var="site") + 
  theme_bw(base_size = 18) +
  ylab("Species Richness") +
  xlab("Number of Quadrats") +
  labs(caption="B=100.")

out.inc4<-iNEXT(site.list.freq.4, q=0, datatype="incidence_freq", size=NULL, nboot=100)
D<-ggiNEXT(out.inc4, type=1, color.var="site") + 
  theme_bw(base_size = 18) +
  ylab("Species Richness") +
  xlab("Number of Quadrats") +
  labs(caption="B=100.")

out.inc5<-iNEXT(site.list.freq.5, q=0, datatype="incidence_freq", size=NULL, nboot=100)
E<-ggiNEXT(out.inc5, type=1, color.var="site") + 
  theme_bw(base_size = 18) +
  ylab("Species Richness") +
  xlab("Number of Quadrats") +
  labs(caption="B=100.")

out.inc6<-iNEXT(site.list.freq.6, q=0, datatype="incidence_freq", size=NULL, nboot=100)
F<-ggiNEXT(out.inc6, type=1, color.var="site") + 
  theme_bw(base_size = 18) +
  ylab("Species Richness") +
  xlab("Number of Quadrats") +
  labs(caption="B=100.")

out.inc7<-iNEXT(site.list.freq.7, q=0, datatype="incidence_freq", size=NULL, nboot=100)
G<-ggiNEXT(out.inc7, type=1, color.var="site") + 
  theme_bw(base_size = 18) +
  ylab("Species Richness") +
  xlab("Number of Quadrats") +
  labs(caption="B=100.")
```

```{r Many curves output, fig.height=25, fig.width=7, include=FALSE}
ggarrange(A, B, C, D, E, F, G, nrow=7)
```
 
```{r Data rearranging, echo=FALSE, fig.height=4, fig.width=10, message=FALSE, warning=FALSE}
Intervals<-select(slice(RichGath, c(28:54)), c(RichLCL, RichUCL))
RichInts<-cbind(RichDivTab, Intervals)
RichInts$PercComplete <- RichInts$RichnessObs/RichInts$RichnessExp*100
RichInts$PercCompleteU<- RichInts$RichnessObs/RichInts$RichUCL*100
RichInts$PercCompleteL<- RichInts$RichnessObs/RichInts$RichLCL*100
sitesizes$QuadsArea<- sitesizes$Quadrats/(pi*(sitesizes$Length^2))
sitesizes$Area<-(pi*(sitesizes$Length^2))
# 
# THIS PLOT IS TRASH
# ggplot(RichInts, aes(x=Site, y=PercComplete)) +
#   geom_bar(aes(y=sitesizes$Quadrats,x=Site), stat="identity", width = 0.75, fill="lightgrey")+
#   geom_point(size=2)+
#   geom_errorbar(aes(ymin=PercCompleteL, ymax=PercCompleteU), width=.3) +
#   ylab("Observed/Expected Richness * 100")+
#   scale_y_continuous(sec.axis = sec_axis(~., name = "Quadrats Sampled"))+
#   ggtitle("Completion percentage and sample size per site")+
#   theme(axis.title=element_text(size=14), plot.title = element_text(size=14))
```

```{r LM Sampling sufficiency, include=FALSE}
lmRichQuad <- lm(RichInts$PercComplete ~ sitesizes$QuadsArea)
autoplot(lmRichQuad)
aRichQuad<-anova(lmRichQuad)
aRichQuad
```

These curves illustrate not only *where* the flattening point (expected richness) occurs, but also *how quickly*. Examining a curve can allow someone to estimate how many more samples would be needed to reach that point, however if doing so samples a larger area then the curve may never flatten. 

Let's see if sampling effort (# quadrats/area sampled) affected percent estimated sampling completion; if it did, that would be a big problem and I would have a lot of explaining to do to my committee.

```{r Sampling sufficiency, echo=FALSE}
ggplot(RichInts, aes(x=sitesizes$QuadsArea, y=PercComplete, color="black")) +
  geom_smooth(method="lm", color="black")+
  geom_text(label=RichInts$Site, color="black", size=3)+
  ylab("Estimated % Species Sampled")+
  xlab(expression(Quadrats~Sampled/Site~Area~(m^2)))+
  ggtitle("Estimated sampling completion does not increase with sampling effort")+
  coord_cartesian(ylim = c(0, 100))+
  theme(axis.title=element_text(size=14), plot.title = element_text(size=14))
```

There is no relationship between sampling effort and completion percentage (p=`r aRichQuad[1,5]`). However, note that Sites 10 and 26 were flagged as outliers by the autoplot function. This inadequate sampling is likely the result of too few quadrats sampled at the wetland edge relative to the size of the wetland. 



## Effects on Diversity

<figure>
<img src="Images/Goosecropped.jpg"></figure><br>

```{r Site size and richness, echo=FALSE, message=FALSE, warning=FALSE}
quaddies<-merge(sitesizes, RichInts, by="Site")
quaddies$Latitude <- as.numeric(as.character(quaddies$Latitude))

ggplot(RichInts, aes(x=sitesizes$Area, y=RichInts$RichnessObs)) +
  geom_point(size=2)+
  ylab("Site richness")+
  xlab(expression(Site~area~(m^2)))+
  ggtitle("Site area does not have a positive affect on site richness")+
  theme(axis.title=element_text(size=14), plot.title = element_text(size=14))
```

There appears to be a relationship between site richness and site area, but unexpectedly this relationship appears to be negative. Because the data are likely non-linear, a generalized linear model should be used to assess this relationship.




## Community Classification

```{r Sorensen time, include=FALSE}
sum01<-rowSums(S01)
sum02<-rowSums(S02)
sum03<-rowSums(S03)
sum04<-rowSums(S04)
sum05<-rowSums(S05)
sum06<-rowSums(S06)
sum07<-rowSums(S07)
sum08<-rowSums(S08)
sum09<-rowSums(S09)
sum10<-rowSums(S10)
sum11<-rowSums(S11)
sum12<-rowSums(S12)
sum13<-rowSums(S13)
sum14<-rowSums(S14)
sum16<-rowSums(S16)
sum17<-rowSums(S17)
sum18<-rowSums(S18)
sum19<-rowSums(S19)
sum20<-rowSums(S20)
sum21<-rowSums(S21)
sum22<-rowSums(S22)
sum23<-rowSums(S23)
sum24<-rowSums(S24)
sum25<-rowSums(S25)
sum26<-rowSums(S26)
sum27<-rowSums(S27)
sum28<-rowSums(S28)

summary<-as.data.frame(rbind(sum01, sum02, sum03, sum04, sum05, sum06, sum07, sum08, sum09, sum10, sum11, sum12, sum13, sum14, sum16, sum17, sum18, sum19, sum20, sum21, sum22, sum23, sum24, sum25, sum26, sum27, sum28))
#TO DELETE SINGLETONS
sumsums<-rbind(sums, summary)
rownames(sumsums)[1]<-"sum"
sumsums1 = sumsums[,sums > 1]
ncol(sumsums[,sums == 1])
#235** singletons!

#Convert to binary
sumsums1[sumsums1 > 0] <- 1

sumsums2<-slice(sumsums1, -c(1))

#0=identical, 1=the most dissimilar
sorensen<-vegdist(sumsums2, method="bray", binary=TRUE, diag=TRUE, upper=FALSE, na.rm = FALSE)
sorensen.m<-as.matrix(sorensen)
sorensen.m.t<-signif(sorensen.m, digits = 3)
```

```{r Distance Matrix, include=FALSE}
sitesizesgeo<-select(sitesizes, c("Site", "Latitude", "Longitude"))
sitesizesgeo.1<-sitesizesgeo[,c(1,3,2)]
sitesizesgeo.2<-sitesizesgeo.1[,c(2,3)]
distance.m<-distm(sitesizesgeo.2)
```

```{r echo=FALSE, message=FALSE, warning=FALSE}
#This is really sloppy
sorensencol<-as.data.frame(sorensen.m.t)
distancecol<-as.data.frame(distance.m)
sorensenmelt<-melt(sorensencol, variable.name = 'Sorensen')
geographicmelt<-melt(distancecol, variable.name = 'Geographic')
distance.1<-cbind(geographicmelt, sorensenmelt)
names(distance.1)<-c("Var1", "geographic", "Var2", "Sorensen")
#Remove zero's because they occur whwere sites match
distance.f<-filter(distance.1, geographic > 0)
```

```{r NMDS, echo=FALSE, message=FALSE, warning=FALSE}
sorensen.nmds01 <- metaMDS(sorensen, k=10)
sorstressplot<-stressplot(sorensen.nmds01)

cluster<-hclust(sorensen, method="average")
grp<-cutree(cluster,6)
plot(sorensen.nmds01, type="text")
ordicluster(sorensen.nmds01, cluster, prune = 7, display = "sites",
         w = weights(sorensen.nmds01, display))
# ordiellipse(sorensen.nmds01, group=grp, display="sites", kind=c("sd"), draw="lines", conf=0.95, lwd=2.6, col="grey44")
```
### Which sites are similar?

There may be a lot of overlap in clusters due to the nestedness of some community types. We should revisit this later using quadrats as replicates.

### Are sites similar because they're geographically closer?

```{r}
ggplot(distance.f, aes(x=distance.f$geographic, y=distance.f$Sorensen)) +
  geom_point()+
  geom_smooth(method="glm", method.args=list(family="binomial"(link="logit")))+
  ylab("Sorensen dissimilarity index")+
  xlab("Geographic distance (m)")+
  ggtitle("Geographic distance between sites has no effect on species similarity")+
  coord_cartesian(ylim = c(0, 1))
```


```{r echo=FALSE, message=FALSE, warning=FALSE}
distance.glm<-glm(Sorensen~geographic, family=binomial, data=distance.f)
summary(distance.glm)
```

Ordinations

## Implications

Plant communities aren't real. We can all go home now.
